@font-face {
    font-family: 'Poppins';
    src: url('../fonts/Poppins Font/Poppins-Regular.ttf');
}

* {
    font-family: "Poppins", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
}

html {
    scroll-behavior: smooth;
}

input:focus,
textarea:focus,
select:focus {
    outline: none;
}


#overShadow {
    width: 100%;
    height: 100%;
    background-color: #000;
    position: fixed;
    top: 0;
    z-index: 480;
    opacity: 30%;
    display: none;
    left: 0;
}
.header_new_responsive_container {
    width: 20%;
    height: 100vh !important;
    left: -100%;
    top: 0;
    box-sizing: border-box;
    text-align: left;
    display: block;
    position: fixed;
    transition: all ease 200ms;
    -ms-overflow-style: none;
    scrollbar-width: none;
    background-color: #fff;
    z-index: 1001;
    overflow-y: scroll;
    display: none;
    padding-top: 5%;
    padding-bottom: 5%;
    border-right: 1px solid rgb(228, 228, 228)
}

.header_new_responsive_container::-webkit-scrollbar {
    display: none;
}




.header_new_responsive_login_container {
    display: flex;
    justify-content: space-around;
    align-items: center;
    padding-top: 5%;
    padding-bottom: 5%;
}

.header_new_responsive_login{
    padding: 2% 4%;
    transition: 0.3s ease;
    border-radius: 10px;
}
.header_new_responsive_login:hover{
    background-color: var(--color_company_1);
    color: #FFF;
}
.header_new_responsive_register{
    padding: 2% 4%;
    transition: 0.3s ease;
    border-radius: 10px;
}
.header_new_responsive_register:hover{
    background-color: var(--color_company_2);
    color: #FFF;
}
.header_new_responsive_logout {
    margin-top: 6%;
    text-align: center;
    padding: 2% 4%;
    transition: 0.3s ease;
}

.header_new_responsive_login {
    border: 1px solid #000;
}

.header_new_responsive_logout {
    border: 1px solid transparent;
    color: #f00;
}

.header_new_responsive_logout:hover {
    background: #f00;
    color: #FFF;
}

.header_new_responsive_logo {
    width: 50%;
    margin-left: 25%;
    padding-bottom: 5%;
}

#header_new_masonry_container {
    height: 100vh !important;
    left: 20%;
    top: 0;
    box-sizing: border-box;
    text-align: left;
    display: none;
    position: fixed;
    transition: all ease 200ms;
    -ms-overflow-style: none;
    scrollbar-width: none;
    background-color: #fff;
    z-index: 1000;
    overflow-y: scroll;
    padding-top: 5%;
    padding-bottom: 5%;
    width: 50%;
}

#header_new_masonry_container::-webkit-scrollbar {
    display: none;
}

.header_new_masonry_category h3 {
    color: var(--color_company_4);
    font-weight: bold;
    margin-left: 15px ;
    text-transform: lowercase;
}

.header_new_masonry_category h3::first-letter {
    text-transform: capitalize;
}




.header_new_masonry_link {
    cursor: pointer;
    margin-right: 100px;
    background-color: white;
    color: var(--color_company_2);
    border-radius: 10px;
    border: 1px solid var(--color_company_2);
    transition: background-color 0.3s ease, color 0.3s ease;
    text-align: center;
    padding-top: 10px;
    padding-right: 5px;
    padding-left: 5px;
    margin-bottom: 10px;
}

.header_new_masonry_link:hover {
    background-color: var(--color_company_2);
    color: white; 
}


.header_new_masonry_title {
    display: flex;
    justify-content: space-between;
}


@media (min-width: 1101px) {
    #header_new_masonry_options {
        column-count: 3;
        column-gap: 0em;
    }
}

/* Para pantallas pequeñas */
@media (max-width: 1250px) {
    #header_new_masonry_options {
        column-count: 2;
        column-gap: 0em;
    }
}
.masonry-item {
    margin: 5px; 
    padding: 10px; 
    display: inline-block; 
    box-sizing: border-box; 
    width: auto; 
    box-sizing: border-box;
    word-break: break-word;
}

.masonry-item p {
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.masonry-item p:hover{
    text-decoration: underline;
}

.masonry-group {
    max-width: auto;
    color: var(--color_company_4); 
    font-weight: bold; 
    font-size: 18px;
}

.masonry-subgroup {
    display: flex;
    flex-direction: row;
    width: 200px; 
    padding-left: 5px;
    padding-bottom: 2px;
    padding-top: 2px;
    color: #000;
    font-size: 15px;
}

.subgroup-container {
    background-color: #f0f0f0; 
    padding: 5px; 
}


.masonry-group, .masonry-subgroup {
    max-width: 100%;
   
}

.masonry-item p::first-letter{
    text-transform: capitalize;
}

.menu-item {
    padding: 5px;
    cursor: pointer;
    box-sizing: border-box;
    word-break: break-word;
}

.menu-item p {
    display: -webkit-box;
    -webkit-line-clamp: 1;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
}

.menu-item p:hover{
    text-decoration: underline;
}



#options_new_menu_movil {
    border: 1px solid #ccc;
   background-color: #FFF;
   padding-left: 10px;
   padding-bottom: 8px;
   padding-top: 8px;
}

.menu-options-container {
    position: relative;
    transition: all 0.2s;
}



.submenu-group, .submenu-subgroup {
    padding: 5px;
    cursor: pointer;
}

.ver-todo {
    background-color: var(--color_company_1); /* Background color */
    color: #FFF; 
    font-weight: bold; 
    padding: 5px; 
    transition: background-color 0.3s ease, color 0.3s ease;
    padding-left: 20px;
}

.ver-todo:hover {
    background-color: white; 
    color: var(--color_company_1);
}


.header_new_responsive_link {
    padding-top: 4%;
    padding-bottom: 4%;
    padding-left: 10%;
    padding-right: 10%;
    border-bottom: 1px solid #a4a4a4;
    text-transform: lowercase;
    transition: 0.3s ease;
}

.header_new_responsive_link::first-letter {
    text-transform: capitalize;
}

.header_new_responsive_link::-webkit-first-letter {
    text-transform: capitalize;
}

.header_new_responsive_link:hover {
    background-color: #ececec;
}

.border-left-color {
    border-left: 5px solid  var(--color_company_4);
}
.header_new_responsive_title {
    padding-top: 4%;
    padding-bottom: 4%;
    padding-left: 3%;
    color: var(--color_company_4);
}

.header_new_responsive_title h5 {
    color: var(--color_company_4);
}



@media screen and (max-width: 768px) {
    .header_new_responsive_container{
        width: 45%;
    }
}


@media (max-width: 1024px) { 
    .header_new_responsive_container {
        width: 25%;
    }
    #header_new_masonry_container {
        left: 25%;
    }
}

@media (max-width: 992px) {
    .header_new_responsive_container {
        width: 30%;
    }

    #overShadow {
        z-index: 500;
    }
}


@media (max-width: 767px) {
    .header_new_responsive_container {
        width: 40%;
    }
}

@media screen and (max-width: 500px) {
    .header_new_responsive_container{
        width: 75%;
    }
}

  
  /* Contenido del modal */
  .modal-content1 {
    background-color: transparent;
    margin: 3% auto; /* 15% from the top and centered */
    padding: 20px;
    border: none;
    width: 40%; /* Could be more or less, depending on screen size */
  }
  
  /* El botón de cierre */
  .close {
    position: absolute;
    color: #aaa;
    float: right;
    font-size: 28px;
    font-weight: bold;
    margin-left: 85%;
    margin-top: -8px;
  }
  
  .close:hover,
  .close:focus {
    color: black;
    text-decoration: none;
    cursor: pointer;
  }

  .modal-img{
    display: flex;
    justify-content: center;
    align-items: center;
}

.modal-img img {
    width: 65%;
    padding-bottom: 5px;
}
.modal-text {
    text-align: justify;
    font-size: 15px;
    padding: 20px;
}
.whatsapp-link {
    display: flex;
    align-items: center;
}

.modalContacto .modal-text {
    text-align: center;
    font-size: 16pt;
    color: #009a49;
}

.modalContacto .contact-info {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.modalContacto .phone-link, .modalContacto .whatsapp-link, .modalContacto .email-link {
    font-size: 14pt;
    color: #009a49;
    display: flex;
    align-items: center;
    gap: 5px;
}

.footer-icon {
    width: 20px;
    height: 20px;
}
.modal-content1 {
    transform: translateY(-100%);
    transition: transform 0.3s ease-out;
  }
  
  .modal-content1.show {
    transform: translateY(0);
  }
  


@media screen and (max-width: 500px) {

    .modal-img img {
        width: 100%;
    }
    .modal-content1 {
    margin-right: 200px;
    }
    .close {
    margin-left: 141%;
    }

    .modal-img{
        width: 282px;
    }
    }